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(54) Printing system for e-mail 

(57) A printing system includes an application 
server for receiving e-mail and for converting the 
received e-mail into print data. A printer adapter 
receives the print data from the application server via a 
communication network, and converts the print data into 
a format which can be received by a printer. A printer 
prints out the print data converted by the printer 
adapter. 
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Description 

BACKGROUND OF THE INVENTION 

Field of the Invention 5 

[0001] The present invention relates to a printing 
system for electronic mail (hereinafter referred to as "e- 
mail"). More particularly, the invention relates to elec- 
tronic mail services by utilizing cellular telephones or 10 
mobile communication terminals, such as personal dig- 
ital assistants (PDAs), and print output services for out- 
putting information to printers connected to a 
communication network. 

75 

Description of the Related Art 

[0002] Hitherto, e-mail services and network print- 
ing services are totally different services and are not 
provided in conjunction with each other. In particular, 20 
cellular telephones and PDA having e-mail functions are 
not provided with printing functions. If it is desired that e- 
mail be printed, it is necessary to first transfer it to a mail 
address assigned to a client personal computer (PC) 
and to then print it out from a printer connected to the 25 
PC. Accordingly, there is no means to print received e- 
mail for e-mail users who possess only cellular tele- 
phones or PDAs. 

[0003] Additionally, in sending e-mail, files can be 
attached, and in order to open a received file attached 30 
to the e-mail, it is necessary to run a corresponding 
application program on a PC. It is thus impossible for e- 
mail users who only possess cellular telephones or 
PDAs without functions to run application programs to 
open received files. 35 
[0004] Generally, in news distribution services utiliz- 
ing e-mail, detailed news information is given on 
homepages on the Internet, and only news summaries 
are distributed to users, and only the homepage 
address, i.e., uniform resource locator (URL), is sent to 40 
the users to instruct them to visit the Internet site corre- 
sponding to the URL to obtain more detailed informa- 
tion. However, since a Web browser is required on a PC 
to visit the Internet site, e-mail users having only cellular 
telephones or PDAs cannot see the details of the dis- 45 
tributed news. 

[0005] In short, it is impossible for e-mail users uti- 
lizing cellular telephones or PDAs without a printing 
function to print out e-mail, run application programs, or 
check the content of files attached to e-mail or addi- 50 
tional information. 

SUMMARY OF THE INVENTION 

[0006] Accordingly, in order to solve the above- 55 
described problems, it is a concern of the present inven- 
tion to provide a simply constructed printing system 
which allows e-mail users utilizing only cellular tele- 



phones or PDAs without a printing function to perform 
printing even if the users do not possess a PC. 
[0007] It is another concern of the present invention 
to improve user operability by allowing printing to be 
performed with a minimal amount of character input, 
such as print commands, in mobile communication ter- 
minals. 

[0008] It is still another concern of the present 
invention to enhance user operability by allowing e-mail 
users utilizing cellular telephones or PDAs to directly 
print out homepages without the need to open the 
homepages on a PC. 

[0009] According to one aspect of the present 
invention, there is provided a printing system including 
an application server, a printer adapter, and a printer. 
The application server receives electronic mail and con- 
verts the received electronic mail into print data. The 
printer adapter receives the print data from the applica- 
tion server via a communication network and converts 
the received print data into a data format matching an 
interface for a printer to which the print data is to be 
sent. The printer prints the print data converted by and 
sent from the printer adapter. 

[0010] According to another aspect of the present 
invention, there is provided a printing control apparatus 
including an analyzing unit and a determining unit. The 
analyzing unit analyzes an address of received elec- 
tronic mail. The determining unit determines a type of 
printing of the received electronic mail according to a 
result of an analysis conducted by the analyzing unit. 
[0011] According to still another aspect of the 
present invention, there is provided a printing control 
apparatus including an input unit, an identifying unit, an 
acquiring unit, a processing unit, and an output unit. 
The input unit inputs an instruction to print a designated 
Internet homepage. The identifying unit identifies infor- 
mation concerning a status or a type of printer. The 
acquiring unit acquires data of the designated Internet 
homepage. The processing unit processes the data 
acquired by the acquiring unit based on the information 
concerning the status or the type of printer identified by 
the identifying unit. The output unit outputs the data 
processed by the processing unit to the printer. 
[0012] According to a further aspect of the present 
invention, there is provided a printing control method 
including an analyzing step and a determining step. In 
the analyzing step, an address of received electronic 
mail is analyzed. In the determining step, a type of print- 
ing of the electronic mail is determined according to a 
result of an analysis conducted in the analyzing step. 
[0013] According to a yet further aspect of the 
present invention, there is provided a printing control 
method including an input step, an identifying step, an 
acquiring step, a processing step, and an output step. In 
the input step, an instruction to print a designated Inter- 
net homepage is input. In the identifying step, informa- 
tion concerning a status or a type of printer is identified. 
In the acquiring step, data of the designated Internet 
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homepage is acquired. In the processing step, the data 
acquired in the acquiring step is processed based on 
the information concerning the status or the type of 
printer identified in the identifying step. In the output 
step, the data processed in the processing step is out- 5 
put to the printer. 

[0014] According to a further aspect of the present 
invention, there is provided a storage medium for stor- 
ing a program. The program includes an analyzing step 
of analyzing an address of received electronic mail, and w 
a determining step of determining a type of printing of 
the electronic mail according to a result of an analysis 
conducted in the analyzing step. 

[0015] According to a further aspect of the present 
invention, there is provided a storage medium for stor- is 
ing a program. The program includes an input step, an 
identifying step, an acquiring step, a processing step, 
and an output step. In the input step, an instruction to 
print a designated Internet homepage is input. In the 
identifying step, information concerning a status or a 
type of printer is identified. In the acquiring step, data of 
the designated Internet homepage is acquired. In the 
processing step, the data acquired in the acquiring step 
is processed based on the information concerning the 
status or the type of printer identified in the identifying 
step. In the output step, the data processed in the 
processing step is output to the printer. 
[0016] According to a further aspect of the present 
invention, there is provided a printer adapter including a 
receiving unit and a converting unit. The receiving unit 
receives print data via a communication network from 
an application server which receives electronic mail 
from a mobile terminal and which converts the received 
electronic mail into the print data. The converting unit 
converts the print data received by the receiving unit 
into a data format corresponding to an interface for a 
printer to which the print data is to be sent. 
[0017] According to a further aspect of the present 
invention, there is provided a printer including a receiv- 
ing unit and a printing unit. The receiving unit receives 
print data from a printer adapter, the print data being 
converted from electronic mail sent from a mobile termi- 
nal by an application server and being sent to the printer 
adapter, in which the print data is converted into a data 
format corresponding to an interface for the printer to 
which the print data is to be sent. The printing unit per- 
forms printing based on the print data received by the 
receiving unit. 

[0018] According to a further aspect of the present 
invention, there is provided a program including an ana- 
lyzing step of analyzing an address of received elec- 
tronic mail, and a determining step of determining a 
type of printing of the electronic mail according to a 
result of an analysis conducted in the analyzing step. 
[0019] According to a further aspect of the present 
invention, there is provided a program including an input 
step, an identifying step, an acquiring step, a processing 
step, and an output step. In the input step, an instruction 



to print a designated Internet homepage is input. In the 
identifying step, information concerning a status or a 
type of printer is identified. In the acquiring step, data of 
the designated Internet homepage is acquired. In the 
processing step, the data acquired in the acquiring step 
is processed based on the information concerning the 
status or the type of printer identified in the identifying 
step. In the output step, the data processed in the 
processing step is output to the printer. 
[0020] According to the present invention con- 
structed as described above, an e-mail user utilizing a 
cellular telephone or a PDA without a printing function 
transfers an e-mail address, which designates a printer, 
within an application server in which the user has been 
registered. Upon receiving this e-mail, the application 
server converts the content to be printed into print data 
corresponding to the registered printer. The application 
server then sends the print data to a printer adapter by 
using a communication network. The adapter converts 
the print data into a data format which can be received 
by the printer. The printer then prints out the converted 
print data. 

[0021] In the application server, a plurality of appli- 
cation programs for opening attached files have been 
registered. An e-mail user utilizing a cellular telephone 
or a PDA without a function of opening attached files 
transfers e-mail with an attached file to the e-mail 
address designating a printer. Upon receiving this e- 
mail, the application server runs the application pro- 
gram corresponding to the attached file and opens the 
file. The application server then converts the content of 
the opened file into print data corresponding to the reg- 
istered printer. The application server sends the con- 
verted print data into an adapter printer by using a 
communication network. The adapter converts the print 
data Into a data format which can be received by the 
printer. The printer then prints out the converted print 
data. 

[0022] Further objects, features and advantages of 
the present invention will become apparent from the fol- 
lowing description of the preferred embodiments with 
reference to the attached drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0023] 

Fig. 1 is a schematic diagram illustrating a system 
according to an embodiment of the present inven- 
tion; 

Fig. 2 is a schematic diagram illustrating a system 
according to another embodiment of the present 
invention; 

Fig. 3 is a schematic diagram illustrating a system 
according to another embodiment of the present 
invention; 

Fig. 4 is a schematic diagram illustrating an applica- 
tion server shown in Figs. 1 through 3; 
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Fig. 5 is a block diagram illustrating a software mod- 
ule within the application server shown in Fig. 4; 
Fig. 6 is a block diagram illustrating the electrical 
configuration of an adapter shown in Figs. 1 
through 3; 

Fig. 7 is a block diagram illustrating the software 
configuration implemented on the adapter shown in 
Fig. 6; 

Fig. 8 is a flow chart illustrating the process per- 
formed by a client, such as a PDA; 
Fig. 9 is a flow chart illustrating the process per- 
formed by a server of a network printing system; 
Fig. 10 is a flow chart illustrating the process per- 
formed by the adapter; 

Fig. 11 is a flow chart illustrating the process per- 
formed by an email object; 

Fig. 12 is a flow chart illustrating the process per- 
formed by a PrinterManager object; 
Fig. 13 is a flow chart illustrating the process per- 
formed by a PrinterDriver object; 
Fig. 14 is a flow chart illustrating the process per- 
formed by a Print J ob object; and 
Fig. 15 is a flow chart illustrating the process per- 
formed by a MailServer object. 

DESCRIPTION OF THE PREFERRED EMBODI- 
MENTS 

[0024] The present invention is described in detail 
below through illustrations of preferred embodiments. 
[0025] Referring to Fig. 1, a system constructed in 
accordance with an embodiment of the present inven- 
tion is formed of the following elements. A terminal 
(hereinafter referred to as a "PDA") 101 is used for 
sending and receiving e-mail and for displaying the con- 
tents of e-mail. Reference numeral 103 indicates a com- 
munication network 103, such as a public switched 
network, an integrated services digital network (ISDN), 
or a satellite communication, (in this embodiment, a 
public switched network). A mobile communication ter- 
minal 102 connects the communication network 103 
and the PDA 1 01 . An Internet service provider 1 04 inter- 
venes between users and the Internet 106, which is a 
logical space. A printer 1 09 serves as a printing appara- 
tus. An adapter 108 is connected to the printer 109. A 
mobile communication terminal 107 connects the com- 
munication network 103 and the adapter 108. An appli- 
cation server 105 communicates with the printer 109 
according to predetermined protocols. 
[0026] The Internet service provider 104 manages 
mail accounts of the PDA 101 , and also communicates 
with the PDA 101 according to predetermined protocols 
so as to send and receive mail data under the control of 
the PDA 101. 

[0027] The application server 1 05 manages various 
items of information, such as a plurality of mail accounts 
and telephone numbers associated with a plurality of 
printers, the types of printers, etc. The application 



server 1 05 also sends and receives mail to and from the 
communication network 103 or the Internet 106 and 
determines the content of the received mail. According 
to the determination result, the application server 105 

5 performs, for example, the following operations; select- 
ing the type of service, such as printing mail text, 
expanding a file attached to the e-mail and printing the 
expanded file, or acquiring the content of the address 
designated by the URL and printing it; converting the 

w data corresponding into the selected service to informa- 
tion unique to the designated printer 109, connecting 
with the adapter 108 (may be connecting with the Inter- 
net 1 06, calling the communication network 1 03 through 
a telephone, and receiving incoming calls from the com- 

15 munication network 1 03 according to the status); per- 
forming authentication with the adapter 108; 
exchanging print data; and handling errors which have 
occurred in the adapter 108 or the printer 109. The 
application server 105 also controls a determination of 

20 whether it is to provide an instruction to immediately 
transfer the print data to the adapter 108 or whether it is 
to await a call from the adapter 108. 
[0028] The adapter 1 08 performs, for example, the 
following operations: identifying errors according to a 

25 determination of the printer 109 connected to the 
adapter 108 and an interface with the printer 109; 
informing the status of the error and the status of the 
communication state to the application server 1 05; con- 
trolling the mobile communication terminal 107; calling 

30 the application server 105 according to a user opera- 
tion; receiving incoming calls from the application server 
105 and performing automatic calling according to an 
instruction from the application server 105; performing 
authentication with the application server 105; and 

35 sending received print data to the printer 1 09 according 
to predetermined protocols. 

[0029] According to the system constructed as 
described above, a description is given below of trans- 
ferring the content of the mail received by the PDA 1 01 

40 to the application server 1 05. 

[0030] The user specifies the user mail address 
related to an application (in this embodiment, mail text) 
to be printed. The user then performs setting so that 
that the mail text to be printed is to be transferred to the 

45 specified address and sends a transfer command to the 
PDA 101. Upon receiving the transfer command, the 
PDA 101 controls the mobile communication terminal 
1 02 to connect the PDA 1 01 to the Internet service pro- 
vider 1 04 via the communication network 1 03. The mail 

50 data is then transferred according to predetermined pro- 
tocols, and data exchanges are appropriately per- 
formed. Then, the network is disconnected to complete 
the mail transfer operation. 

[0031] Meanwhile, the application server 1 05 scans 
55 (regularly checks) the incoming boxes of the accounts. 
Upon receiving the print data, the application server 1 05 
performs the above-described processing according to 
a predetermined order. The configurations of the indi- 
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vidual elements of the system according to an embodi- 
ment of the present invention are discussed in detail 
below. 

[0032] Fig. 4 is a diagram illustrating the application 
server 105 schematically shown in Fig. 1 according to 
this embodiment. 

[0033] A firewall server 3101 has the function of 
protecting the application server 1 05 from invasions and 
attacks from external sources, and is used for safely 
operating a group of Intranet servers within the applica- 
tion server 105. 

[0034] A switch 3102 is used for constituting the 
Intranet within the application server 1 05 of this embod- 
iment. A communication server 3103 supports connec- 
tions performed by the Personal Handyphone System 
(PHS) Internet Access Forum Standard (PIAFS), by 
analog modems, and by ISDN, and has a firewall func- 
tion and a remote authentication dial-in user service 
(RADIUS) client function. 

[0035] A network print server 3104 provides net- 
work print services, such as obtaining print data accord- 
ing to the purpose of printing, creating a print job, and 
performing communications with the adapter 108. 
[0036] A RADIUS server 31 05 is a standard dial-up 
connection user authentication system. The RADIUS 
server 31 05 receives an authentication request from the 
communication server 3103 having a RADIUS client 
function and returns an authentication response to the 
client. 

[0037] A mail server 3106 receives print request 
mail. A WWW server 3107 possesses homepages of 
the network print services of this embodiment. The 
WWW server 31 07 provides a user homepage for each 
user and also provides each user with a function of con- 
trolling print services by using, for example, the com- 
mon gateway interface (CGI). Reference numeral 3109 
indicates the Internet, and 3108 represents a public 
switched telephone network (PSTN) or a PHS network. 
[0038] The mail printing function of the application 
server 105 constructed as described above, as shown 
in Fig. 4, is as follows. 

[0039] Before receiving e-mail print services, a user 
of the network print service of this embodiment obtains 
an e-mail account of the mail server 3106 within the 
application server 105. By sending e-mail to this 
account, the user is able to receive print services. 
[0040] A plurality of the above-mentioned e-mail 
accounts are assigned to each user according to the 
number of services to be provided. In this embodiment, 
assuming that the following four types of services are 
provided, four e-mail accounts are provided for each 
user. 

1. printing e-mail text 

2. printing attached files 

3. printing e-mail text and attached files 

4. printing URL 



By sending e-mail to the mail account of service 1, the 
user requests the application server 105 to create print 
data of e-mail text By sending e-mail to the mail 
account of service 2, the user requests the application 

5 server 1 05 to create print data of a file attached to the e- 
mail. By sending e-mail to the mail account of service 3, 
the user requests the application server 1 05 to generate 
print data of e-mail text and an attached file. By sending 
e-mail to the mail account of service 4, the user 

70 requests the application server 105 to acquire the 
hypertext markup language (HTML), the extensible 
markup language (XML), etc. corresponding to the URL 
described in the e-mail text, and to create the print data 
thereof. 

15 [0041] If e-mail without an attached file is sent to the 
e-mail address of service 2 or 3, or if e-mail without a 
URL is sent to the e-mail address of service 4, print data 
indicating only e-mail text is created. 
[0042] If e-mail containing only an attached file is 

20 sent to the e-mail address of service 1 , print data repre- 
senting only the attached file is created. If e-mail con- 
taining only a URL is sent to the e-mail address of 
service 1 , print data representing only the URL is gener- 
ated. 

25 [0043] If an HTML has not been successfully 
acquired, or if there is a mistake in a URL even though 
e-mail containing the URL is sent to the mail address of 
service 4, the occurrence of an error is reported to the 
user from the application server 105. 

30 [0044] It is now assumed that the domain name of 
the mail server 3106 of this embodiment is mnp.co.jp 
and that the user has acquired an account designated 
as "tama". In this case, the mail server 3106 automati- 
cally prepares the following e-mail accounts. 

35 [0045] In the system constructed in accordance 
with this embodiment, four addresses are determined 
as follows: the account "tama" is used for printing e-mail 
text; the account "tama" + A is used for printing an 
attached file; the account "tama" + B is used for printing 

40 e-mail text and an attached file; and the account "tama" 
+ C is used for printing a URL. 

1. tama@mnp.co.jp (printing e-mail text) 

2. tamaA@mnp.co.jp (printing attached files) 

45 3. tamaB@mnp.co.jp (printing e-mail text and 
attached files) 

4. tamaC@mnp.co.jp (printing URL) 

The above-mentioned addresses are registered in a 
so database of the application server 1 05, in which case, 
the telephone number of the mobile communication ter- 
minal 107 required for establishing a connection with 
the printer 109 when e-mail is sent may be also regis- 
tered in a database of the RADIUS server 3105 in cor- 
55 respondence with the four addresses. Information 
indicating the type of printer 109 may also be registered 
* in the database of the RADIUS server 3105. 
[0046] The user, tama, is able to select the e-mail 
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printing function by the above-described addresses. 
Since such printing functions and the e-mail addresses 
are registered in correspondence with each other, the 
user is able to set the address merely by selecting the 
registered address through a mobile communication 
terminal. Thus, according to this embodiment of the 
present invention, it is possible for the user to select the 
address and to set the printing function at the same time 
without the need to input a print command. 
[0047] Fig. 5 is a block diagram illustrating a soft- 
ware module within the application server 1 05. 
[0048] Physically, a MailServer (em ail Manager) 
3202 is disposed within the mail server 3106. The 
MailServer 3202 has an internet messaging access pro- 
tocol (I MAP) server function so as to interpret multipart 
Multipurpose Internet Mail Extensions (MIME) and to 
inform users (in this embodiment, to an email (IMAP cli- 
ent) object 3203) of the arrival of mail. 
[0049] The email object 3203 has data to be printed 
and a user ID (in this case, an e-mail address). The 
email object 3203 has an IMAP client function so that it 
is able to extract the individual parts of multipart MIME 
mail from an IMAP server (in this embodiment, email- 
Manager 3202) according to the MIME type. The email 
object 3203 also has the function of delivering print data 
to a PrinterManager object 3205. 

[0050] A PrinterDB 3204 stores information of the 
individual users and provides a database access func- 
tion to the PrinterManager 3205, a UserHTMLPage 
3209, and an HTMLPage 3210. The information of the 
individual users includes the following items. 

UserlD (user name when registering in the network 
printing system) 

UserPassword (password when registering in the 
network printing system) 

Use rTeIN umber (telephone number when register- 
ing in the network printing system) 
AdapterlD (ID unique to the adapter) 
AdapterTelNumber (the telephone number of the 
terminal to which the adapter is connected) 
PrinterlD (printer ID obtained via IEEE 1284) 

The above-mentioned items of information are set for 
each user when registering in the network printing sys- 
tem. 

[0051] The PrinterManager object 3205 has an ID 
of a PrinterDriver object 3206. By using functions of 
managing (creating, erasing, counting, stopping, etc.) 
the PrinterDriver object 3206 and the user ID (in this 
case, the e-mail address) as keys, the PrinterManager 
object 3205 is able to search the PrinterDB 3204, and 
creates a suitable PrinterDriver object according to the 
PrinterlD obtained from the DB and delivers print data. 
The creation of the PrinterDriver object is for the selec- 
tion of a printer driver corresponding to the printer and 
for starting the selected printer driver. 
[0052] The PrinterDriver object 3206 is created for 



each printer according to the PrinterlD. The PrinterMan- 
ager object 3205 retains items of information, such as 
the AdapterTelNumber, the AdapterlD, and the PrinterlD 
corresponding to the user ID, obtained from the 

5 PrinterDB 3204, and converts the print data to a format 
suitable for a specific printer. In printing an attached file, 
the PrinterManager object 3205 determines the applica- 
tion type of the attached file from the MIME type, and 
starts the corresponding application so as to convert the 

10 attached file to the corresponding format. 

[0053] A PrintJob object 3207 is created for each 
PrinterDriver object 3206. The PrintJob object 3207 
retains items of information, such as the AdapterTel- 
Number, the AdapterlD, and the PrinterlD correspond- 

15 ing to the user ID, acquired in creating the PrintJob 
3207, and also retains print data created by the Printer- 
Driver object 3206. Thus, the PrintJob object 3207 has 
the functions of queuing print data and outputting it to 
the adapter 108 according to the AdapterTelNumber. 

20 [0054] A WebBrowser object 3208 has a WWW 
browsing function. In response to a message from the 
PrinterDriver object 3206 to obtain an HTML, the Web- 
Browser object 3208 obtains an HTML from a desig- 
nated URL and performs rendering. 

25 [0055] The UserHTMLPage object 3209, which is a 
Web Page created for each user, possesses user infor- 
mation, such as a default printer. The UserHTMLPage 
object 3209 also has the functions of reflecting the print 
status using the CGI, controlling a print job by sending a 

30 job control message to the PrinterDriver object 3206, 
and updating the user setting by reflecting data received 
by using the hypertext transfer protocol (HTTP) in the 
DB. Additionally, in response to a request from the Prin- 
terManager object 3205, the UserHTMLPage object 

35 3209 also serves the function of reflecting the print sta- 
tus in the user homepage of the network printing sys- 
tem. 

[0056] The HTMLPage 3210 is a homepage of the 
domain which forms the network printing system of this 

40 embodiment, and has the user registering function. 

[0057] A RADIUSServer 3211 is equivalent to the 
RADIUS server 3105 shown in Fig. 4. A PortMaster 
(Radius client) 3212 is equivalent to the communication 
server 31 03 shown in Fig. 4. 

45 [0058] A PDA 3201 , which is a communication ter- 
minal, is equivalent to the PDA 101 shown in Fig. 1, and 
at least has the mail sending/receiving function and may 
also be provided with an HTML browsing function. 
[0059] An Adapter 321 3 is equivalent to the adapter 

50 1 08 shown in Fig. 1 , and a Printer 321 4 is equivalent to 
the printer 109 shown in Fig. 1 . 

[0060] Physically, the PDA 3201 and the Adapter 
321 3 are connected to the network printing system via a 
communication terminal (not shown), such as a PHS. 
55 [0061] A description is now given, with reference to 
Fig. 5, of the process of receiving e-mail, creating a print 
job, and sending it to the adapter 1 08 by the application 
server 1 05. 
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[0082] A user of the network print services sends e- 
mail to be printed by using a mail terminal, such as the 
PDA 3201 . The e-mail is sent to the address of the serv- 
ice desired by the user, as discussed above. 
[0063] In practice, the e-mail sent to the application 5 
server 105 is received by the mail server 3202. As 
stated above, the mail server 3202 of this embodiment 
has the IMAP server function. Thus, the mail server 
3202 reports the arrival of mail to the email object 3203 
provided for each user, which has the IMAP client func- 10 
tion and is disposed within the network print server 
3104, according to the IMAP protocol. 
[0064] The email object 3203 acquires a target 
MIME part corresponding to the mail address according 
to the IMAP protocol. The obtained data is then trans- 15 
ferred to the PrinterManager object 3205. 
[0065] The PrinterManager object 3205 searches 
the PrinterDB 3204 for the user information (for exam- 
ple, the ID of the default printer) by using the user ID 
indicated by the e-mail account. Subsequently, the Prin- 20 
terManager object 3205 creates the PrinterDriver object 
3206 associated with the obtained default printer. 
[0066] The PrinterDriver object 3206 obtains data 
to be printed from the PrinterManager object 3205, and 
converts it to print data so as to create the Print Job 25 
object 3207. 

[0067] If the data to be printed is an URL, the 
PrinterDriver object 3206 sends the URL to the Web- 
Browser object 3208. The WebBrowser object 3208 
then acquires the content of the URL (such as HTML or 30 
XML) designated through the Internet, and returns it to 
the PrinterDriver object 3206 after performing rendering 
on the content. The PrinterDriver object 3206 converts 
the rendered data to print data, thereby creating the 
PrintJob object 3207. 35 
[0068] If the content of the URL has not been suc- 
cessfully obtained due to, for example, the elapse of a 
predetermined period because of a poor communica- 
tion status or a mistake in the address, the WebBrowser 
object 3208 returns an error signal to the PrinterDriver 40 
object 3206. The PrinterDriver object 3206 also notifies 
the PrinterManager object 3205 that an error has 
occurred, and the email object 3203 composes mail 
indicating the occurrence of an error and sends the mail 
to the user. 45 
[0069] Thereafter, the print data stored in the Print- 
Job object 3207 is transferred to the adapter 1 08. In this 
embodiment, there are two approaches to transferring 
the print data, that is, by the application server 1 05 call- 
ing and by the adapter 1 08 calling. so 
[0070] The print data can be transferred by adapter 
108 (3213) calling when the adapter 108 logs in the 
application server 105. In this case, the Adapter 3213 
telephones the PortMaster 3212 to log in the application 
server 1 05 by using the AdapterlD, the AdapterTelNum- 55 
ber, and the PrinterlD as authentication keys. The 
authentication keys are transferred from the PortMaster 
3212 to the PrinterDB 3204 via the RADIUSServer 



321 1 and are checked in the PrinterDB 3204. The con- 
nection between the Adapter 3213 and the application 
server 105 is established by the transmission control 
protocol/internet protocol (TCP/IP), and the internet 
protocol (IP) address assigned to the Adapter 3213 by 
the PortMaster 3212 is a private address of the network 
printing system of this embodiment. 
[0071] The Adapter 3213, which was allowed to log 
in according to the above-described process, sends a 
print-data request message to the PrinterManager 
object 3205. 

[0072] Upon receiving the message, the Printer- 
Manager object 3205 specifies the PrintJob object 3207 
that matches the AdapterlD, the AdapterTelNumber, 
and the PrinterlD corresponding to the Adapter 3213, 
and sends a message to the PrintJob object 3207 to 
instruct it to send the data. This message contains the 
IP address of the Adapter 3213. 

[0073] The PrintJob object 3207 sends the print 
data to the designated IP address, i.e., to the address of 
the Adapter 3213, according to the LPR protocol. 
[0074] As the other approach to transferring the 
print data, when the application server 105 calls, it 
requests the PortMaster 3212 to call the PrinterTelNum- 
ber possessed by the PrintJob object 3207. 
[0075] In response to a request from the application 
server 105, the PortMaster 3212 telephones the Printer- 
TelNumber, in which case, the PortMaster 3212 reports 
the telephone number of the network printing system to 
the Adapter 321 3. After obtaining the telephone number 
of the network printing system, the Adapter 3213 tem- 
porarily disconnects communications, and then calls 
back the acquired telephone number. The subsequent 
operation is similar to that when the adapter 108 per- 
forms calling. 

[0076] The aforementioned four mail addresses, 
the adapter 108 connected to the printer 109, and the 
telephone number of the mobile terminal 107 are regis- 
tered in the database in correspondence with each 
other. Accordingly, the telephone number can be identi- 
fied from the received mail address, and the print data 
can be created and sent to the adapter 1 08 by using the 
mobile terminal 107 via a public communication net- 
work. 

[0077] The print job stored in the PrintJob object 
3207 may be created in units of pages, considering that 
only one piece of paper is stored in the Printer 321 4 (the 
printer in which sheets of paper are manually fed one by 
one). In this case, the printer type is identified based on 
the PrinterlD (printer type information) so as to deter- 
mine the unit for feeding the print job. For example, mul- 
tiple-page data is sent as one job to a cassette-feeding- 
type printer, while single-page data is sent as one job to 
a manual-feeding-type printer. With this arrangement, 
the re-sending of data, which is required when an error 
or a jam occurs, can be easily performed, thereby facili- 
tating the recovery from an error or a jam. 
[0078] While sending print data from the PrintJob 
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object 3207 to the Adapter 3213, an error, such as 
paper running out, may be reported from the Adapter 
3213 to the PrintJob object 3207. In this case, the Print- 
Manager object 3205 receives an error report from the 
Adapter 3213, and sends to the PrinterDriver object 5 
3206 a message which instructs the PrinterDriver object 

3206 to stop sending the print data, thereby interrupting 
the transferring of the print data from the PrintJob object 

3207 to the Adapter 3213. 

[0079] In this case, the PrinterDriver object 3206 w 
may request the email object 3203 to report the occur- 
rence of an error to the user. The PrinterDriver object 
3206 may also request the UserHTMLPage object 3209 
to update the print status reflecting an error within the 
homepage of the network printing system. 15 
[0080] Fig. 6 is a block diagram illustrating the elec- 
trical configuration of the adapter 108. 
[0081] The adapter 108 used in this embodiment is 
connected to the mobile communication terminal 107 
via a communication terminal interface 2101 and con- 20 
nects the terminal 107 to an internal bus 2108. This 
communication terminal interface 2101 absorbs differ- 
ent electrical characteristics of various communication 
terminals when being connected to the internal bus 
2108. 25 
[0082] That is, the adapter 1 08 is used for convert- 
ing a protocol of a data format of a communication inter- 
face, such as a PHS, to a protocol of a data format of a 
printer interface, such as the Centronics interface. 
[0083] The printer 1 09 is connected to the internal 30 
bus 21 08 of the adapter 1 08 via a printer interface 21 04. 
Connected to the internal bus 2108 are a microcom- 
puter 2102 for controlling overall operation, a read only 
memory (ROM) 2105 for storing the internal operation 
program and the content of setting, a random access 35 
memory (RAM) 21 06 for temporarily storing an area for 
running a program, data to be sent, and received data, 
and a user interface (U/l) 2103 for setting, registering, 
and displaying the user operation performed on the 
adapter 108. The ROM 2105 is an overwritable ROM, 40 
and not only adds and modifies software, but also adds 
new protocols. 

[0084] In obtaining new data, the ROM 21 05 down- 
loads the data via the interface 2101 or 2104 so as to 
overwrite the internal program. The ROM 2105 also 45 
stores the telephone number required for connecting 
the adapter 108, the adapter ID, and so on. 
[0085] The microcomputer 2102 has a capacity for 
implementing modems and protocols by software. A 
power source 2107 is used for operating the adapter 50 
108. 

[0086] Fig. 7 illustrates the configuration of the soft- 
ware implemented on the adapter 108. In the adapter 
1 08, which is shown on the right side of Fig. 7, a com- 
munication network (carrier) protocol 2207 for establish- 55 
ing a connection with the mobile communication 
terminal 1 07 is implemented on the layer higher than an 
hardware {HAN) 2208, which is physically connected to 
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the mobile communication terminal 107. In practice, the 
adapter 1 08 is connected to the communication network 
103 via the mobile communication terminal 107. 
Accordingly, the communication network protocol 2207 
controls calling for connecting the adapter 108 to the 
communication network 103, receiving incoming calls 
from the communication network 1 03, disconnecting the 
adapter 108 from the communication network 103, etc. 
[0087] A protocol 2206 is implemented on the layer 
higher than the communication network protocol 2107 
and includes the TCP/IP and a protocol unique to the 
carrier. An application 2205 communicates with the 
communication network 1 03 via the protocol 2206. 
[0088] In this embodiment, since the communica- 
tion network protocol 2207, the protocol 2206, and the 
application 2205 are implemented by software, they are 
implemented by the microcomputer 2102, the ROM 
2105, and the RAM 2106 shown in Fig. 6. 
[0089] The communication control operation per- 
formed in accordance with the present invention is as 
follows. 

[0090] In this embodiment, the adapter 1 08 and the 
printer 109 are connected with the IEEE 1284 interface 
2104. When connected to the printer 109, the adapter 

108 obtains the printer ID from the printer 1 09 by nego- 
tiations of IEEE 1284 of the interface 2104. 

[0091 ] If the printer 1 09 is not working since it is not 
powered on, a predetermined printer ID is set, or the 
use of the adapter 108 is prohibited since the printer 

109 is unknown. 

[0092] The acquired (or set) printer ID is stored in 
the ROM 2105 or the RAM 2106 via the internal bus 
2108. If the printer 109 does not have an automatic 
detecting function, the ID cannot be correctly obtained, 
in which case, an arbitrarily set ID is stored in the ROM 
2105 or the RAM 2106. This is set by the user or is 
determined by the application server 105. The acquired 
ID is also used as an ID for authentication, which will be 
discussed below. 

[0093] A description is given below of the communi- 
cation control operation when, for example, data com- 
munications are performed between the adapter 108 
and the application server 1 05. 

[0094] An external interface provided for the mobile 
communication terminal 107 externally controls, via the 
interface 2101, calling for the communication network 
103, receiving incoming calls, and disconnecting the 
communication terminal 107 from the communication 
network 103. 

[0095] The microcomputer 21 02 controls calling for 
the mobile communication terminal 107, receiving 
incoming calls, and disconnecting the adapter 1 08 from 
the communication terminal 107 via the interface 2101 . 
In response to a request from an external source, the 
mobile communication terminal 107 outputs the tele- 
phone number thereof via the external interface. The 
adapter 108 is then able to obtain the telephone number 
of the connected communication terminal, or it may 
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reject the connection if the telephone number is not a 
correct one. Either the application server 105 or the 
adapter 108 may call the mobile communication termi- 
nal 107. 

[0096] The telephone number is received from the 
application server 105 as data, and the adapter 108 
calls back the application server 105 by using the same 
telephone number after disconnecting the communica- 
tions. 

[0097] Both the application server 105 and the 
mobile communication terminal 107 are connected to 
the communication network 1 03. If the mobile communi- 
cation terminal 1 07 is a wireless type, it is connected to 
the communication network 1 03 via a wireless base sta- 
tion. 

[0098] The adapter 1 08 calls the telephone number 
through the mobile communication terminal 107 so that 
the adapter 108 can be connected to the application 
server 105. Then, the mobile communication terminal 
107 attempts to connect to the communication network 
103 by the above-described telephone number. In this 
case, the establishment of the connection is based on 
the type of communication network. 
[0099] When the communication terminal of the 
application server 105 receives a call from the mobile 
communication terminal 107, the connection between 
the adapter 108 and the application server 105 in the 
communication network 103 is established. 
[0100] Authentication is then performed on the con- 
nection by using a protocol higher than the communica- 
tion network 103 if, for example, the telephone number 
of the communication terminal 107 that has called the 
application server 105 is not a registered number. 
[0101] In this embodiment, authentication is made 
by using an authentication packet. The connection to 
the application server 105 is authenticated by using 
"adapter authentication". The information used for 
authentication is prepared as an "authentication 
packet", which is then sent from the adapter 108 to the 
application server 105 when they are connected. 
[0102] The authentication packet includes the fol- 
lowing items of information: AdapterlD, AdapterTelNum- 
ber, and iPrinterlD. The iPrinterlD is obtained by 
negotiations of the IEEE 1284 interface, as discussed 
above, and is used not only for performing authentica- 
tion, but also for selecting a data-creating driver. 
[0103] When the connection between the applica- 
tion server 105 and the adapter 108 and communica- 
tions between protocols are established, 
communications are performed between the corre- 
sponding layers of the application server 1 05 and the 
adapter 1 08, as shown in Fig. 7. 

[0104] After the communications have been estab- 
lished and authentication has been successfully per- 
formed, it is ready to start data communication. Thus, 
the adapter 108 processes data sent from the applica- 
tion server 105. The adapter 108 also sends the status 
of the connected printer 109 and the status of the 



adapter 108 to the application server 105. By referring 
to those statuses, the application server 105 converts 
the format of data to be sent, or divides or compresses 
the data. Also, the adapter 108 notifies error informa- 

5 tion, such as paper running out or ink running low, to the 
application server 105 as a status. 
[0105] In the layer higher than the protocol, data 
sent from the application server 105, which contains a 
command for controlling the printer 109 or the adapter 

w 108, is obtained. Instead of controlling the printer 109 or 
the adapter 1 08 by this command, the whole data may 
be delivered to the printer 109 and processed therein. 
[01 06] For example, the adapter 1 08 may output the 
data containing a printer command to the printer 109 

is without changing the data, and the printer 1 09 performs 
printing. 

[0107] The application server 105 enlarges or 
reduces the data size in accordance with a paper size of 
the printer 109, so that the data can be easily modified. 

20 [0108] Additionally, by reporting the type of ink 
stored in the printer 109 to the application server 105, 
the color mode or the monochrome mode can be auto- 
matically switched in the application server 105. Simul- 
taneously, a warning may be issued via the user 

25 interface 2013. 

[0109] As discussed above, the content of e-mail 
data is directly converted into print data, or the content 
of e-mail data is interpreted as a command and certain 
processing is executed on the command so as to create 

30 print data. Wrth this arrangement, by merely modifying 
the data output from the application server 105, the 
processing content of the data to be output to the 
adapter 108 and the printer 109 can be changed. Addi- 
tionally, complicated processing or functions which are 

35 not provided for the adapter 1 08 can be executed in the 
application server 105, thereby reducing the load in the 
adapter 108 to a minimal level. 

[0110] The flow of the processing content of each 
device is discussed below. The program corresponding 

40 to each flow is stored in a memory of each device and is 
run by a central processing unit (CPU). 
[0111] Fig. 8 is a flow chart illustrating the client 
processing performed by the PDA 101 shown in Fig. 1. 
In step S3301, a client composes a document to be 

45 printed as mail. In step S3302, the client selects the 
printing function, such as printing text, printing an 
attached file, etc. Then, in step S3303, the client sends 
the mail to the address implementing the selected print- 
ing function. 

so [0112] Fig. 9 is a flow chart illustrating the process 
executed by the application server 1 05, and more spe- 
cifically, the process executed by the application server 
105 when typical mail printing functions are imple- 
mented in the network printing system. 

55 [0113] In step S3401, the MailServer3202 having a 
simple mail transfer protocol (SMTP) server function 
and the IMAP server function waits for mail to be 
received. Upon receiving mail, the MailServer 3202 
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notifies the email object 3203 according to the IMAP 
that the mail has been received. Details of step S3401 
are shown in Fig. 15. When receiving a notification that 
the mail has been received from the MailServer 3202, 
the email object 3203 having the IMAP client function 5 
receives required part from the MailServer 3202. There- 
after, in step S3402, the email object 3203 gives a print- 
ing instruction to the PrinterManager 3205. Details of 
step S3402 are shown in Fig. 1 1. 

[0114] In response to the printing instruction from w 
the email object 3203, in step S3403, the PrinterMan- 
ager 3205 refers to the PrinterDB 3204 from the UserlD 
so as to obtain the print ID consisting of the UserlD, the 
UserTe IN umber, the UserPassword, the AdapterlD, the 
AdapterTelNumber, and the PrinterlD. Then, the Printer- 15 
Manager 3205 creates the PrinterD river object 3206 
indicated by the PrinterlD and delivers data to be 
printed to the PrinterDriver object 3206. Details of step 
S3403 are shown in Fig. 12. 

[0115] In step S3404, if the printing function is for 20 
printing text, the PrinterDriver object 3206 performs ren- 
dering on text. If the printing function is for printing an 
attached file, the PrinterDriver object 3206 runs a suita- 
ble application and performs rendering. If the printing 
function is for printing a URL, the PrinterDriver object 25 
3206 requests the WebBrowser object 3208 to obtain 
an HTML and to perform rendering on the HTML. 
Thereafter, the PrinterDriver object 3206 performs 
image processing and color processing so as to create 
the PrintJob object 3207. Details of step S3404 are 30 
shown in Fig. 13. 

[0116] In step S3405, the PrintJob object 3207 con- 
nects itself to the adapter 1 08 according to the printer ID 
and attempts to output print data. Details of step S3405 
are shown in Fig. 14. 35 
[0117] Fig. 1 0 is a flow chart illustrating the process 
performed by the adapter 108. In step S3501, the 
adapter 1 08 is connected to the network printing system 
by calling the adapter 1 08 itself or calling back the appli- 
cation server 1 05. Then, in step S3502, the adapter 1 08 40 
performs authentication by using the RADIUSServer 
3211, and when connected, the adapter 108 requests 
the PrinterManager object 3205 to transfer a print job. In 
step S3503, the adapter 1 08 then waits for the print job 
to be transferred from the Printjob object 3207. In step 45 
S3504, upon receiving the print job, the adapter 108 
sends the print data to the printer 1 09 via the IEEE 1284 
interface. Simultaneously, the adapter 108 handles a 
status, such as an error, sent from the printer 1 09. 
[0118] Fig. 1 5 is a flow chart illustrating the process so 
executed by the mail server 3106 within the application 
server 105. In step S4001, the mail server 31 06 having 
the SMTP server function and the IMAP server function 
provides e-mail sending/receiving services, and it waits 
for mail to be received. In step S4002, upon receiving 55 
mail, the mail address is analyzed. In step S4003, the 
mail server 31 06 then notifies the IMAP client 3203 that 
the mail has been received. 



[01 1 9] Fig. 1 1 is a flow chart illustrating the process 
executed by the email object 3203 of the network print 
server 31 04 within the application server 105. 
[0120] In step S3601, the email object 3203, which 
is created for each user, waits for a notification of the 
arrival of e-mail from the mail server 31 06. 
[0121] In step S3602, upon receiving the e-mail, the 
email object 3203 analyzes the mail address. In step 
S3603, S3605, S3607, and S3610, the email object 
3203 selects a printing function, such as printing text, an 
attached file, text and an attached file, or a URL. 
[0122] For example, all of the following mail 
addresses are received by the user, tama. 

1. tama@mnp.co.jp 

2. tamaA@mnp.co.jp 

3. tamaB@mnp.co.jp 

4. tamaC@mnp.co.jp 

It is now assumed that address 1 is for printing text, 
address 2 is for printing attached files, address 3 is for 
printing text and attached files,. and address 4 is for 
printing URLs. The email object 3203 created for the 
user, tama, analyzes these addresses and executes 
necessary processing, as stated below. 
[01 23] If it is determined in step S3603 that the mail 
address is for printing text, the process proceeds to step 
S3604 in which the email object 3203 extracts the text 
part from the mail server 31 06 by designating the MIME 
type. Then, in step S3613, the email object 3203 adds a 
printing function ID indicating that text is to be printed, 
and requests the PrinterManager 3205 to perform 
processing. 

[0124] If it is found in step S3605 that the mail 
address is for printing an attached file, the process pro- 
ceeds to step S3606 in which the email object 3203 
extracts the attached file from the mail server 3106 by 
specifying the MIME type. Then, in step S3613, the 
email object 3203 adds a printing function ID indicating 
that an attached file is to be printed, and requests the 
PrinterManager 3205 to perform processing. 
[0125] If it is found in step S3607 that the mail 
address is for printing text and an attached file, the 
email object 3203 extracts the text part and an attached 
file from the mail server 3106 by designating the MIME 
type in steps S3608 and S3609. Then, in step S3613, 
the email object 3203 adds a printing function ID indi- 
cating that text and an attached file are to be printed, 
and requests the PrinterManager 3205 to execute 
processing. 

[0126] If it is determined in step S3610 that the 
address is for printing an URL, the email object 3203 
extracts the text part from the mail server 31 06 by spec- 
ifying the MIME type in step S361 1 and also extracts the 
URL from the text in step S3612. Then, in step S3613. 
the email object 3203 adds a printing function ID indi- 
cating that the URL is to be printed, and requests the 
PrinterManager 3205 to perform processing. 
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[0127] Fig. 12 is a flow chart illustrating the process 
performed by the PrinterManager 3205 of the network 
print server 31 04 within the application server 105. 
[0128] In step S3701, the PrinterManager 3205 
waits for a message from the email object 3203 or the 
Adapter 3213 to be received. 

[0129] If it is found in step S3702 that a message is 
from the Adapter 3213, the PrinterManager 3205 
checks the AdapterlD and the PrinterlD in step S3703. 
Then, in step S3704, the PrinterManager 3205 sends a 
message to the PrinterDriver object 3206 and controls 
the operation (stop, restart, delete, etc.) according to 
the type of message, thereby performing control (stop, 
restart, delete, etc.) of the print job. 
[0130] If it is determined in step S3705 that a mes- 
sage is from the email object 3203 and indicates a print- 
ing instruction, the PrinterManager 3205 checks the 
UserlD in step S3706, and searches the PrinterDB 
3204 in step S3707. The ID checked by the PrinterMan- 
ager 3205 includes a print ID consisting of the UserlD, 
the UserTeIN umber, the UserPassword, the AdapterlD, 
the AdapterTelNumber, and the PrinterlD. 
[0131] If it is found in step S3708 that the PrinterlD 
of the print ID is printer A, the PrinterDriver object 3206 
for printer A is created in step S3709. 
[0132] If it is found in step S371 0 that the PrinterlD 
of the print ID is printer B, the PrinterDriver object 3206 
for printer B is created in step S371 1 . 
[0133] If it is found in step S371 2 that the PrinterlD 
of the, print ID is printer C, the PrinterDriver object 3206 
for printer C is created in step S3713. 
[0134] Printer A, printer B, and printer C are, for 
example, an ink jet printer made by company A, a laser 
beam printer made by company B, and a thermal printer 
made by company C, respectively. The PrinterDriver 
object 3206 matching the corresponding printer is cre- 
ated (the corresponding driver is selected and started). 
[0135] If it is determined in step S3714 that the 
message received by the PrinterManager object 3205 is 
an error message, error mail corresponding to the type 
of error is sent to the UserlD in step S3715. Then, in 
step S371 6, the PrinterManager object 3205 notifies the 
UserHTMLPage object 3209 that an error has occurred, 
and requests the UserHTMLPage object 3209 to reflect 
the corresponding status in the user homepage. 
[0136] Fig. 1 3 is a flow chart illustrating the process 
performed by the PrinterDriver object 3206 of the net- 
work print server 31 04 within the application server 105. 
[0137] Upon receiving the print data, the corre- 
sponding MIME type, the print ID, and the printing func- 
tion ID (text/attached file/URL) from the PrinterManager 
object 3205, the PrinterDriver object 3206 is started. 
[0138] If it is determined in step S3801 that the 
printing function ID and the print data indicate text, the 
PrinterDriver object 3206 performs rendering on the text 
in step S3802. The PrinterDriver object 3206 then per- 
forms image processing and color processing in step 
S3803, and creates the PrintJob object 3207 in step 



S3804. 

[0139] If it is found in step S3805 that the printing 
function ID and the print data represent an attached file, 
the PrinterDriver object 3206 determines the file format 

5 according to the MIME type. 

[01 40] If it is found in step S3806 that the file format 
is format A, the PrinterDriver object 3206 runs the ren- 
dering application for format A and performs rendering 
in step S3807. Then, the PrinterDriver object 3206 per- 

10 forms image processing and color processing in step 
S3803, and creates the PrintJob object 3207 in step 
S3804. 

[0141] If it is determined in step S3808 that the file 
format is format B, the PrinterDriver object 3206 runs 
75 the rendering application for format B and performs ren- 
dering in step S3809. Then, the PrinterDriver object 
3206 performs image processing and color processing 
in step S3803, and creates the PrintJob object 3207 in 
step S3804. 

20 [0142] If it is determined in step S3810 that the file 
format is format C, the PrinterDriver object 3206 starts 
the rendering application for format C and performs ren- 
dering in step S3811. Then, the PrinterDriver object 
3206 performs image processing and color processing 

25 in step S3803, and creates the PrintJob object 3207 in 
step S3804. 

[01 43] Format A, format B, and format C may be, for 
example, PostScript made by Adobe Systems Incorpo- 
rated, WORD made by Microsoft Corporation, Joint 
30 Photographic Experts Group (JPEG), and Graphics 
Interchange Format (GIF). 

[0144] If it is determined in step S3812 that the 
printing ID indicates an URL, the PrinterDriver object 
3206 requests the WebBrowser object 3208 to acquire 

35 the URL in step S3813. 

[01 45] If it is determined in step S381 4 that the ren- 
dered HTML data of the web page indicated by the URL 
has been successfully obtained, the PrinterDriver object 
3206 performs image processing and color processing 

40 in step S3803, and creates the PrintJob object 3207 in 
step S3804. 

[0146] If the printing function ID is unknown, or if a 
message indicating that the HTML data of the web page 
designated by the URL has not been successfully 
45 obtained is sent from the WebBrowser object 3208, the 
PrinterDriver object 3206 notifies the PrinterManager 
object 3205 that an error has occurred, and stops the 
printing operation. 

[01 47] Fig. 1 4 is a flow chart illustrating the process 
so executed by the PrintJob object 3207 of the network 
print server 31 04 within the application server 105. 
[0148] In step S3901, the PrintJob object 3207 
waits for a print start message to be received. 
[0149] In step S3902, upon receiving the print start 
55 message after completing the processing of the Printer- 
Driver object 3206, the PrintJob object 3207 attempts to 
connect itself to the Adapter 3213 via the communica- 
tion server 3103. 
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[0150] If it is found in step S3903 that the PrinUob 
object 3207 has been successfully connected to the 
Adapter 3213, the PrinUob object 3207 checks the 
PrinterlD of the Adapter 3213 in step S3904. If it is 
determined in step S3905 that the PrinterlD has 5 
matched, the PrinUob object 3207 sends the print data 
to the Adapter 3213 in step S3906. In this case, if the 
Print J ob object 3207 determines from the PrinterlD that 
the printer is not provided with a paper tray, it may divide 
the print job into page units. Thereafter, the PrinUob 10 
object 3207 sends the print data to the Adapter 3213 by 
using a protocol, such as LPR. 

[0151] If it is found in step S3903 that the PrinUob 
object 3207 has not been successfully connected to the 
Adapter 3213, or if it is found in step S3905 that the 15 
PrinterlD is not a correct one, the process proceeds to 
step S3907 in which the PrinUob object 3207 notifies 
the PrinterDriver object 3206 that an error has occurred. 
[0152] Figs. 2 and 3 are schematic diagrams illus- 
trating a system according to another embodiment of 20 
the present invention. 

[0153] The elements similar to those shown in Fig; 
1 are designated by like reference numerals. Step 1 and 
step 2 of Figs. 2 and 3, respectively, show the same sys- 
tem at different times. More specifically, the mobile com- 25 
munication terminal 102 is shared by the adapter 108 
and the PDA 101 in this system, and Fig. 2 illustrates 
the system when the PDA 101 is connected to the 
mobile communication terminal 102, while Fig. 3 illus- 
trates the system when the adapter 1 08 is connected to 30 
the mobile communication terminal 102. 
[0154] The user operates the PDA 1 01 to send mail 
to be printed. After transferring mail data and discon- 
necting the line, the user connects the mobile communi- 
cation terminal 102 to the adapter 108 and the printer 35 
109. The user also operates the switch provided for the 
adapter 1 08 so as to connect it to the application server 
1 05. This enables the user to obtain print data from the 
application server 1 05 and to print out the mail data. 
[0155] Various modifications may be made to the 40 
above-described embodiments. For example, a per- 
sonal computer may be substituted for the PDA 101. 
Although in the foregoing embodiments the mobile com- 
munication terminal 102 is a wireless type, such as a 
PHS or a personal digital cellular (PDC), it may be a 45 
cable-type terminal, such as a modem. The mobile 
communication terminal 102 and the PDA 101 may be 
integrated into a single device which sends and 
receives mail by being connected to the communication 
network 103. Additionally, although in the foregoing so 
embodiments the PDA 101 and the mobile communica- 
tion terminal 1 02 are used as a system for sending and 
receiving mail, this system may be constructed by a 
modem and a computer system. Accordingly, a local 
area network (LAN) may be constructed instead of the 55 
communication network 103, in which case, advantages 
similar to those exhibited by the aforementioned 
embodiments are obtained. 



[0156] The type of the printer 1 09 is not a limitation 
to implement the present invention, and any type of 
printer, such as a laser beam printer and an ink jet 
printer, may be used. The same applies to the interface 
21 04 between the adapter 1 08 and the printer 1 09, and 
the interface 2104 is not restricted to the IEEE 1284 
interface, and may be RS232C, a Universal Serial Bus 
(USB), Infrared Data Association (IRD), or an IEEE 
1394 interface may be used. 

[0157] It is also possible to integrate the adapter 
1 08 into the printer 1 09. 

[0158] In the above-described embodiments, the 
print data is converted in the application server 105. 
However, it may be converted in the adapter 108, in 
which case, advantages similar to those exhibited by 
the foregoing embodiments can be offered. 
[0159] As a medium for storing software control 
programs implementing the above-described flows for 
achieving the present invention, not only a ROM, but 
also a floppy disk, a hard disk, an optical disc, a CD- 
ROM, a CD-R, a magnetic disk, a non-volatile memory 
card, etc., may be used. 

[0160] As is seen from the foregoing description, 
the network printing system of the present invention 
offers the following advantages. 

[0161] As discussed above, the network printing 
system is formed of an application server for receiving 
e-mail, a printer adapter being connected to the applica- 
tion server via a communication network, and a printer. 
It is thus possible to allow e-mail terminals without a. 
printing function to perform printing. E-mail terminals 
without a function of opening attached files or additional 
information (such as homepages on the Internet) are 
able to refer to attached files and additional information. 
[01 62] Merely by adding a service to the application 
server, all the e-mail terminals with or without a printing 
function are able to receive the added service. Since 
conventional e-mail protocols are applied to this net- 
work printing system, the above-described functions 
can be provided without the need to modify conven- 
tional e-mail terminals. 

[0163] It is thus possible to provide a simply con- 
structed printing system which allows users utilizing a 
cellular telephone or a PDA without a printing function to 
perform printing even rf the users do not own a PC. 
[0164] It is possible to enhance user operability by 
allowing printing to be performed with a minimal amount 
of character input in a mobile terminal. User operability 
can also be improved by enabling the user utilizing a 
cellular telephone or a PDA to print homepages without 
opening them on a PC. 

[0165] While the present invention has been 
described with reference to what are presently consid- 
ered to be the preferred embodiments, it is to be under- 
stood that the invention is not limited to the disclosed 
embodiments. On the contrary, the invention is intended 
to cover various modifications and equivalent arrange- 
ments included within the spirit and scope of the 
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appended claims. The scope of the following claims is to 
be accorded the broadest interpretation so as to 
encompass all such modifications and equivalent struc- 
tures and functions. 

Claims 

1 . A printing system comprising: 

an application server for receiving electronic 
mail and for converting the received electronic 
mail into print data; 

a printer adapter for receiving the print data 
from said application server via a communica- 
tion network and for converting the received 
print data into a data format matching an inter- 
face for a printer to which the print data is to be 
sent; and 

a printer for printing the print data converted by 
and sent from said printer adapter. 



said application server comprises means for obtain- 
ing the information concerning the status or the 
type of said printer by using the communication net- 
work. 

5 

10. A printing system according to claim 1, wherein 
said application server divides a job of the print 
data in units of pages when the print data corre- 
sponds to a plurality of pages, and sends the 

10 divided job to said printer. 

11. A printing system according to claim 1, wherein 
said application server stores a print job of the elec- 
tronic mail from a registered user, and selects the 

15 print job to provide a printing instruction. 

12. A printing system according to claim 1, wherein 
said printer adapter is contained in said printer. 

20 13. A printing control apparatus comprising: 



2. A printing system according to claim 1, wherein 
contents of the electronic mail to be printed is sent 
to said application server from a mobile terminal by 
using the electronic mail. 

3. A printing system according to one of claims 1 and 
2, wherein the contents to be printed comprises 
electronic mail text, an attached file, and an Internet 
homepage. 

4. A printing system according to claim 1, wherein 
said printer is selected by an electronic-mail 
address. 

5. A printing system according to claim 1 , wherein a 
type of printing is designated by an e-mail address. 

6. A printing system according to claim 5, wherein the 
type of printing comprises printing electronic-mail 
text, printing an attached file, printing electronic- 
mail text and an attached file, and printing a uniform 
resource locator. 

7. A printing system according to claim 1 , wherein the 
print data is sent from said application server to 
said printer adapter via a mobile terminal by using 
the communication network. 

8. A printing system according to claim 1, wherein 
said application server converts a content of the 
received electronic mail into the print data which is 
optimal for said printer according to information 
concerning a status or a type of said printer, and 
sends the print data to said printer adapter by using 
the communication network. 

9. A printing system according to claim 8, wherein 



analyzing means for analyzing an address of 
received electronic mail; and 
determining means for determining a type of 
25 printing of the received electronic mail accord- 

ing to a result of an analysis conducted by said 
analyzing means. 

14. A printing control apparatus according to claim 13, 
30 wherein the type of printing determined by said 

determining means comprises printing electronic- 
mail text, printing an attached file, printing elec- 
tronic-mail text and an attached file, and printing an 
Internet homepage. 

35 

15. A printing control apparatus according to one of 
claims 13 and 14, wherein said determining means 
determines the type of printing of the received elec- 
tronic mail based on a mail address account. 

40 

16. A printing control apparatus comprising: 

input means for inputting an instruction to print 
a designated Internet homepage; 

45 identifying means for identifying information 

concerning a status or a type of printer; 
acquiring means for acquiring data of the des- 
ignated Internet homepage; 
processing means for processing the data 

so acquired by said acquiring means based on the 

information concerning the status or the type of 
printer identified by said identifying means; and 
output means for outputting the data processed 
by said processing means to the printer. 

55 

17. A printing control apparatus according to claim 16, 
wherein said processing means processes data 
corresponding to a plurality of pages as data corre- 



13 



25 

sponding to a plurality of jobs. 

18. A printing control apparatus according to one of 
claims 16 and 17, wherein the instruction to print 
the designated Internet homepage is provided by 5 
sending electronic mail. 

19. A printing control apparatus according to claim 16, 
wherein said output means outputs the data based 

on a call from the printer after performing authenti- w 
cation. 

20. A printing control apparatus according to claim 16, 
wherein said processing means processes data 
corresponding to a plurality of pages as data corre- 15 
sponding to a plurality of jobs or processes data 
corresponding to a plurality of pages as data corre- 
sponding to a single job according to the type of 
printer. 

20 

21. A printing control apparatus according to claim 16, 
wherein said output means outputs the data when 
said printing control apparatus calls and reports a 
telephone number of said printing control apparatus 

to said printer and when said printer calls back the 25 
reported telephone number. 

22. A printing control apparatus according to claim 16, 
wherein said processing means selects and starts 

a printer driver corresponding to said printer, and 30 
processes the data by the started driver. 

23. A printing control method comprising: 

an analyzing step of analyzing an address of 35 
received electronic mail; and 
a determining step of determining a type of 
printing of the electronic mail according to a 
result of an analysis conducted in said analyz- 
ing step. 40 

24. A printing control method according to claim 23, 
wherein the type of printing determined in said 
determining step comprises printing electronic-mail 
text, printing an attached file, printing electronic- 45 
mail text and an attached file, and printing an Inter- 
net homepage. 

25. A printing control method according to one of 
claims 23 and 24, wherein said determining step 50 
determines the type of printing of the received elec- 
tronic mail based on a mail address account. 



26 

concerning a status or a type of printer; 
an acquiring step of acquiring data of the des- 
ignated Internet homepage; 
a processing step of processing the data 
acquired in said acquiring step based on the 
information concerning the status or the type of 
printer identified in said identifying step; and 
an output step of outputting the data processed 
in said processing step to the printer. 

27. A printing control method according to claim 26, 
wherein said processing step processes data corre- 
sponding to a plurality of pages as data corre- 
sponding to a plurality of jobs. 

28. A printing control method according to one of 
claims 26 and 27, wherein the instruction to print 
the designated Internet homepage is provided by 
sending electronic mail. 

29. A printing control method according to claim 26, 
wherein said output step outputs the data based on 
a call from the printer after performing authentica- 
tion. 

30. A printing control method according to claim 26, 
wherein said processing step processes data corre- 
sponding to a plurality of pages as data corre- 
sponding to a plurality of jobs or processes data 
corresponding to a plurality of pages as data corre- 
sponding to a single job according to the type of 
printer. 

31. A printing control method according to claim 26, 
wherein said output step outputs the data when 
said printing control apparatus calls and reports a 
telephone number of said printing control apparatus 
to said printer and when said printer calls back the 
reported telephone number. 

32. A printing control method according to claim 26, 
wherein said processing step selects and starts a 
printer driver corresponding to said printer, and 
processes the data by the started driver. 

33. A printing control apparatus according to claim 1 3, 
further comprising means for acquiring data based 
on a uniform resource locator contained in mail text, 
for processing the acquired data, and for sending 
the processed data to a printer when said determin- 
ing means determines the type of printing to be 
printing an Internet homepage. 

34. A printing control method according to claim 23, fur- 
ther comprising the step of acquiring data based on 
a uniform resource locator described in mail text, 
processing the acquired data, and sending the 
processed data to a printer when said determining 



26. A printing control method comprising: 

55 

an input step of inputting an instruction to print 

a designated Internet homepage; 

an identifying step of identifying information 
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step determines the type of printing to be printing 
an Internet homepage. 

35. A printing control apparatus according to claim 13, 
wherein electronic-mail text is to be printed when 
said determining means determines that an Inter- 
net homepage is to be printed and when a uniform 
resource locator is not described in the electronic- 
mail text. 

36. A printing control method according to claim 23, 
wherein electronic-mail text is to be printed when 
said determining step determines that an Internet 
homepage is to be printed and when a uniform 
resource locator is not described in the electronic- 
mail text. 

37. A printing system according to one of claims 1 and 
2, wherein said application server sends error mail 
to a mobile terminal when a predetermined period 
elapses because of a poor communication status, 
there is a mistake in an address, or a uniform 
resource locator is not successfully obtained. 

38. A printer adapter comprising: 

receiving means for receiving print data via a 
communication network from an application 
server which receives electronic mail from a 
mobile terminal and which converts the 
received electronic mail into the print data; and 
converting means for converting the print data 
received by said receiving means into a data 
format corresponding to an interface for a 
printer to which the print data is to be sent. 

39. A printer comprising: 

receiving means for receiving print data from a 
printer adapter, the print data being converted 
from electronic mail sent from a mobile termi- 
nal by an application server and being sent to 
said printer adapter, in which the print data is 
converted into a data format corresponding to 
an interface for said printer to which the print 
data is to be sent; and 

printing means for performing printing based 
on the print data received by said receiving 
means. 

40. A printing system according to claim 1, wherein 
contents of the electronic mail to be printed are sent 
from a personal computer to said application server 
by using electronic mail. 

41. A printing system according to claim 1, wherein the 
print data is sent from said application server to 
said printer adapter by using a public network. 



42. A printing control apparatus according to one of 
claims 13 and 16, further comprising an application 
server. 

5 43. A printing control method according to one of 
claims 23 and 26, wherein said printing control 
method is employed in an application server. 

44. A program comprising: 

w 

an analyzing step of analyzing an address of 
received electronic mail; and 
a determining step of determining a type of 
printing of the electronic mail according to a 
15 result of an analysis conducted in said analyz- 

ing step. 

45. A program according to claim 44, wherein the type 
of printing determined in said determining step 

20 comprises printing electronic-mail text, printing an 
attached file, printing electronic-mail text and an 
attached file, and printing an Internet homepage. 

46. A program according to one of claims 44 and 45, 
25 wherein said determining step determines the type 

of printing of the received electronic mail based on 
a mail address account. 

47. A program comprising: 

30 

an input step of inputting an instruction to print 
a designated Internet homepage; 
an identifying step of identifying information 
concerning a status or a type of printer; 

35 an acquiring step of acquiring data of the des- 

ignated Internet homepage; 
a processing step of processing the data 
acquired in said acquiring step based on the 
information concerning the status or the type of 

40 printer identified in said identifying step; and 

an output step of outputting the data processed 
in said processing step to the printer. 

48. A program according to claim 47, wherein said 
45 processing step processes data corresponding to a 

plurality of pages as data corresponding to a plural- 
ity of jobs. 

49. A program according to one of claims 47 and 48, 
so wherein the instruction to print the designated Inter- 
net homepage is provided by sending electronic 
mail. 

50. A program according to claim 47, wherein said out- 
55 put step outputs the data based on a call from the 

printer after performing authentication. 

51. A program according to claim 47, wherein said 
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processing step processes data corresponding to a 
plurality of pages as data corresponding to a plural- 
ity of jobs or processes data corresponding to a plu- 
rality of pages as data corresponding to a single job 
according to the type of printer. 5 

52. A program according to claim 47, wherein said out- 
put step outputs the data when said printing control 
apparatus calls and reports a telephone number of 
said printing control apparatus to the printer and 10 
when the printer calls back the reported telephone 
number. 

53. A program according to claim 47, wherein said 
processing step selects and starts a printer driver 15 
corresponding to said printer, and processes the 
data by the started driver. 

54. A program according to claim 45, wherein elec- 
tronic-mail text is to be printed when said determin- 20 
ing step determines that the Internet homepage is 

to be printed and when a uniform resource locator 
is not described in the electronic-mail text. 

55. A program according to one of claims 45 and 47, 25 
wherein said program is executed in an application 
server. 

56. A storage medium storing processor implementa- 

ble instructions for controlling a processor to carry 30 
out the method of any one of claims 23 to 32, or 
claim 34, or claim 36. 

57. An electrical signal conveying processor imple- 
mentable instructions for controlling a processor to 35 
carry out the method of any one of claims 23 to 32, 

or claim 34, or claim 36. 
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